package com.example.dbmeta.exception;

import com.example.dbmeta.api.vo.CommonConstant;
import com.example.dbmeta.api.vo.Result;
import com.example.dbmeta.meta.log.BaseCommonService;
import com.example.dbmeta.meta.log.LogDTO;
import lombok.extern.slf4j.Slf4j;

import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.RestControllerAdvice;

import javax.annotation.Resource;

/**
 * 异常处理器
 * 
 * @Author scott
 * @Date 2019
 */
@RestControllerAdvice
@Slf4j
public class DbmetaExceptionHandler {

	@Resource
	BaseCommonService baseCommonService;

	/**
	 * 处理自定义异常
	 */
	@ExceptionHandler(DbMetaBootException.class)
	public Result<?> handleDbDetaException(DbMetaBootException e){
		log.error(e.getMessage(), e);
		addSysLog(e);
		return Result.error(e.getErrorCode(), e.getMessage());
	}
	
//	/**
//	 * 处理自定义异常
//	 */
//	@ExceptionHandler(JeecgBootBizTipException.class)
//	public Result<?> handleJeecgBootBizTipException(JeecgBootBizTipException e){
//		log.error(e.getMessage());
//		return Result.error(e.getErrCode(), e.getMessage());
//	}
//
//	/**
//	 * 处理自定义微服务异常
//	 */
//	@ExceptionHandler(JeecgCloudException.class)
//	public Result<?> handleJeecgCloudException(JeecgCloudException e){
//		log.error(e.getMessage(), e);
//		addSysLog(e);
//		return Result.error(e.getMessage());
//	}
//
//	/**
//	 * 处理自定义异常
//	 */
//	@ExceptionHandler(JeecgBoot401Exception.class)
//	@ResponseStatus(HttpStatus.UNAUTHORIZED)
//	public Result<?> handleJeecgBoot401Exception(JeecgBoot401Exception e){
//		log.error(e.getMessage(), e);
//		addSysLog(e);
//		return new Result(401,e.getMessage());
//	}
//
//	@ExceptionHandler(NoHandlerFoundException.class)
//	public Result<?> handlerNoFoundException(Exception e) {
//		log.error(e.getMessage(), e);
//		addSysLog(e);
//		return Result.error(404, "路径不存在，请检查路径是否正确");
//	}
//
//	@ExceptionHandler(DuplicateKeyException.class)
//	public Result<?> handleDuplicateKeyException(DuplicateKeyException e){
//		log.error(e.getMessage(), e);
//		addSysLog(e);
//		return Result.error("数据库中已存在该记录");
//	}
//
//	@ExceptionHandler({UnauthorizedException.class, AuthorizationException.class})
//	public Result<?> handleAuthorizationException(AuthorizationException e){
//		log.error(e.getMessage(), e);
//		return Result.noauth("没有权限，请联系管理员分配权限！");
//	}
//
//	@ExceptionHandler(Exception.class)
//	public Result<?> handleException(Exception e){
//		log.error(e.getMessage(), e);
//		//update-begin---author:zyf ---date:20220411  for：处理Sentinel限流自定义异常
//		Throwable throwable = e.getCause();
//		SentinelErrorInfoEnum errorInfoEnum = SentinelErrorInfoEnum.getErrorByException(throwable);
//		if (ObjectUtil.isNotEmpty(errorInfoEnum)) {
//			return Result.error(errorInfoEnum.getError());
//		}
//		//update-end---author:zyf ---date:20220411  for：处理Sentinel限流自定义异常
//		addSysLog(e);
//		return Result.error("操作失败，"+e.getMessage());
//	}
//
//	/**
//	 * @Author 政辉
//	 * @param e
//	 * @return
//	 */
//	@ExceptionHandler(HttpRequestMethodNotSupportedException.class)
//	public Result<?> httpRequestMethodNotSupportedException(HttpRequestMethodNotSupportedException e){
//		StringBuffer sb = new StringBuffer();
//		sb.append("不支持");
//		sb.append(e.getMethod());
//		sb.append("请求方法，");
//		sb.append("支持以下");
//		String [] methods = e.getSupportedMethods();
//		if(methods!=null){
//			for(String str:methods){
//				sb.append(str);
//				sb.append("、");
//			}
//		}
//		log.error(sb.toString(), e);
//		//return Result.error("没有权限，请联系管理员授权");
//		addSysLog(e);
//		return Result.error(405,sb.toString());
//	}
//
//	 /**
//	  * spring默认上传大小100MB 超出大小捕获异常MaxUploadSizeExceededException
//	  */
//    @ExceptionHandler(MaxUploadSizeExceededException.class)
//    public Result<?> handleMaxUploadSizeExceededException(MaxUploadSizeExceededException e) {
//    	log.error(e.getMessage(), e);
//		addSysLog(e);
//        return Result.error("文件大小超出10MB限制, 请压缩或降低文件质量! ");
//    }
//
//    @ExceptionHandler(DataIntegrityViolationException.class)
//    public Result<?> handleDataIntegrityViolationException(DataIntegrityViolationException e) {
//    	log.error(e.getMessage(), e);
//		addSysLog(e);
//    	//【issues/3624】数据库执行异常handleDataIntegrityViolationException提示有误 #3624
//        return Result.error("执行数据库异常,违反了完整性例如：违反惟一约束、违反非空限制、字段内容超出长度等");
//    }
//
//    @ExceptionHandler(PoolException.class)
//    public Result<?> handlePoolException(PoolException e) {
//    	log.error(e.getMessage(), e);
//		addSysLog(e);
//        return Result.error("Redis 连接异常!");
//    }
//
//
//	/**
//	 * SQL注入风险，全局异常处理
//	 *
//	 * @param exception
//	 * @return
//	 */
//	@ExceptionHandler(JeecgSqlInjectionException.class)
//	public Result<?> handleSQLException(Exception exception) {
//		String msg = exception.getMessage().toLowerCase();
//		final String extractvalue = "extractvalue";
//		final String updatexml = "updatexml";
//		boolean hasSensitiveInformation = msg.indexOf(extractvalue) >= 0 || msg.indexOf(updatexml) >= 0;
//		if (msg != null && hasSensitiveInformation) {
//			log.error("校验失败，存在SQL注入风险！{}", msg);
//			return Result.error("校验失败，存在SQL注入风险！");
//		}
//		addSysLog(exception);
//		return Result.error("校验失败，存在SQL注入风险！" + msg);
//	}

	//update-begin---author:chenrui ---date:20240423  for：[QQYUN-8732]把错误的日志都抓取了 方便后续处理，单独弄个日志类型------------
	/**
	 * 添加异常新系统日志
	 * @param e 异常
	 * @author chenrui
	 * @date 2024/4/22 17:16
	 */
    private void addSysLog(Throwable e) {
        LogDTO log = new LogDTO();
        log.setLogType(CommonConstant.LOG_TYPE_4);
        log.setLogContent(e.getClass().getName()+":"+e.getMessage());
//		log.setRequestParam(ExceptionUtils.getStackTrace(e));
//        //获取request
//        HttpServletRequest request = null;
//        try {
//            request = SpringContextUtils.getHttpServletRequest();
//        } catch (NullPointerException | BeansException ignored) {
//        }
//        if (null != request) {
//			//请求的参数
//			Map<String, String[]> parameterMap = request.getParameterMap();
//			if(!CollectionUtils.isEmpty(parameterMap)){
//				log.setMethod(oConvertUtils.mapToString(request.getParameterMap()));
//			}
//            // 请求地址
//            log.setRequestUrl(request.getRequestURI());
//            //设置IP地址
//            log.setIp(IpUtils.getIpAddr(request));
//            //设置客户端
//			if(BrowserUtils.isDesktop(request)){
//				log.setClientType(ClientTerminalTypeEnum.PC.getKey());
//			}else{
//				log.setClientType(ClientTerminalTypeEnum.APP.getKey());
//			}
//        }

       
//		//获取登录用户信息
//		LoginUser sysUser = (LoginUser) SecurityUtils.getSubject().getPrincipal();
//		if(sysUser!=null){
//			log.setUserid(sysUser.getUsername());
//			log.setUsername(sysUser.getRealname());
//
//		}

        baseCommonService.addLog(log);
    }
	//update-end---author:chenrui ---date:20240423  for：[QQYUN-8732]把错误的日志都抓取了 方便后续处理，单独弄个日志类型------------

}
